草庐IT

iphone - iOS : NSString retrieving a substring from a string

全部标签

c++ - boost::asio::io_service 在 win_mutex 锁中崩溃

我一直在使用boost::asio时遇到问题,其中使用全局io_service实例创建的计时器和/或套接字在构造期间崩溃。发生崩溃的系统如下:Windows7适用于Windows桌面的VisualStudio2013Express;v12.0.31101.00更新4Boost1.57,动态链接,使用多线程编译,例如boost_thread-vc120-mt-gd-1_57.dll我已经能够在以下简化代码中重现该问题://文件global_io_service.h#ifndefINCLUDED_GLOBAL_IO_SERVICE_H#defineINCLUDED_GLOBAL_IO_SE

c++ - std::string 分配何时在初始化时发生

当我在类中创建一个std::string成员变量时,是否在实例化时已经分配了默认内存?还是std::string延迟分配直到它被实际使用?我目前正在使用VisualStudio2010,我注意到,当我创建一个空字符串时:std::strings0;std::strings1="";两者都有容量==15套。那么这是否意味着它已经分配了15个字节的内存?如果是,我可以阻止这种情况以便不分配内存吗?这会是跨不同编译器的特定实现吗? 最佳答案 标准未指定空std::string的初始容量,并且取决于实现。许多实现会分配大约16个字符的初始容

c++ - 为什么 cout.setf(ios::fixed) 将我的 float 更改为十六进制?

我最近遇到了这个与cout.setf(ios::fixed)有关的奇怪问题。我花了很长时间才找到原因,我想我会在这里询问以了解更多信息。问题在于-使用cout.setf(ios::fixed)时,所有float都打印为十六进制数。为什么会这样?ios::base的文档似乎并不暗示这会发生(至少对我而言)。我使用的是g++5.3.0,下面粘贴的是一个最小示例和输出。#include#includeusingnamespacestd;intmain(intargc,charconst*argv[]){complexI(0.0,1.0);doublepi=M_PI;cout.setf(ios

c++ - 如何在 constexpr string_view 上使用 std::string_view::remove_prefix()

std::string_view::remove_prefix()和std::string_view::remove_suffix()都是c中的constexpr成员函数++17;但是,它们会修改调用它们的变量。如果值是constexpr,它也将是const并且不能修改,那么这些函数如何用于constexpr值?换句话说:constexprstd::string_viewa="asdf";a.remove_prefix(2);//compileerror-aisconst如何在constexprstd::string_view上使用这些函数?如果它们不能在constexprstd::s

c++ - 为什么没有类似于 std::string_view 的 view<T>

我知道std::string_view是对字符串的非拥有引用和std::string_view之间的主要区别和std::string是现在,为什么std::string_view不适用于其他类型?或者为什么这个实现只针对std::string?例如:如果我们有类似的generic_view其中T可以是任何类型,包括自定义类型。有了这个,而不是使用constT&作为函数参数,generic_view可以使用。以及std::string_view的其他优势将很有用,如分配、复制等。 最佳答案 C++20中有一个非拥有类型,用于任意对象的

c++ - 在 C++ 的编译时检查类型是否为 std::basic_string<T>

我在我的C++代码中定义了is_string:#includetemplatestructis_string{staticconstboolvalue=false;};templatestructis_string>{staticconstboolvalue=true;};intmain(){std::cout::value::value对于std::string和std::wstring都是如此。但我需要这样的谓词:is_string::value//tobetrueis_string::value//tobefalseis_string::value//tobefalseis_st

c++ - string::capacity/reserve() 算作终止 null 吗?

从cppref对capacity()的描述来看并不明显和reserve()是否计算终止空字符。 最佳答案 标准statesthat:Inallcases,size().和size()不包括终止空值。因为有可能size()等于capacity(),在这种情况下,这意味着capacity()也不计算终止空值。请注意,在C++11及更高版本中,mystring.c_str()相当于mystring.data()相当于&mystring[0],和mystring[mystring.size()]保证是'\0'.检查这个Demo.

c++ - 无法手动调用 std::string 的析构函数

我正在试验union,并将这个示例设为A类,其中包含匿名union成员。由于union包含一个std::string和一个std::vector我需要为该类定义一个析构函数。但是,当我尝试手动调用~string()时,我得到了union.cpp:Indestructor'A::~A()':union.cpp:14:14:error:expectedclass-namebefore'('tokens_.~string();我不明白这个vector。如果我删除对s._~string();的调用,它可以正常编译。这是编译器错误吗?我正在使用MinGW64。#include#includecl

c++ - IO 完成端口 : How does WSARecv() work?

我想使用工作线程池和IO完成端口编写一个服务器。服务器应该在多个客户端之间处理和转发消息。“每个客户”数据位于ClientContext类中。此类实例之间的数据使用工作线程进行交换。我认为这是一个典型的场景。但是,我对那些IO完成端口有两个问题。(1)第一个问题是服务器基本上从客户端接收数据,但我不知道是否收到了完整的消息。事实上,WSAGetLastError()总是返回WSARecv()仍在挂起。我试图用WaitForMultipleObjects()等待事件OVERLAPPED.hEvent。但是,它会永远阻塞,即WSARecv()在我的程序中永远不会完成。我的目标是绝对确保在进

c++ - 在 C++ 文件中使用 iPhone 资源

我想知道您如何从C++文件打开应用程序包中的文件。即我有一个开始复制到应用程序包中的文件“manifest.xml”。我需要一种从C++加载此文件的方法。我认为这将涉及在Obj-C代码中的某个位置设置路径,以便文件位于工作目录中。 最佳答案 您必须使用CoreFoundation(C)或Foundation(ObjC)。您的应用程序包(“主包”)中的每个对象都可以使用CFBundle/NSBundle函数访问。在CoreFoundation中你这样做(省略NULL检查):CFURLRefmanifest_url=CFBundleCo